php - Symfony2,FOSRestBundle - 捕获异常
全部标签 我的应用程序(Ruby1.9.2)可能会引发不同的异常,包括网络连接中断。我rescueException=>e,然后执行case/when以不同的方式处理它们,但是我的案例中有几个错误直接到else.rescueException=>epe.classcasee.classwhenErrno::ECONNRESETp1whenErrno::ECONNRESET,Errno::ECONNABORTED,Errno::ETIMEDOUTp2elsep3endend打印:Errno::ECONNRESET3 最佳答案 这是因为===运算
我有一个方法可以对Cat模型执行一些操作,如果输入不正确会引发异常:context"hungrycat"doit{expect{eat(what:nil)}.toraise_error}end我想做的是检查这个方法是否改变了猫的状态,就像那样:context"hungrycat"doit{expect{eat(what:nil)}.toraise_error}it{expect{eat(what:nil)}.not_tochange(cat,:status)}end问题在于,由于eat(what:nil)将引发异常,因此第二个it无论如何都会失败。那么,是否可以忽略异常并检查某些条件?
我正在编写一个应用程序,它使用普通的旧Ruby对象(PORO)从Controller中抽象出授权逻辑。目前,我有一个名为NotAuthorized的自定义异常类,我在Controller级别rescue_from,但我很想知道:DoesRails4alreadycome有一个异常(exception)表明某项操作未获授权?我是否通过实现此异常(exception)来重新发明轮子?澄清:引发AuthorizationException不会发生在Controller内部的任何地方,它发生在Controller外部完全分离的PORO内部。该对象不知道HTTP、路由或Controller。
我正在寻找异常处理经典问题的解决方案。考虑以下代码:deffoo(n)puts"for#{n}"sleepnraise"after#{n}"endbeginthreads=[][5,15,20,3].eachdo|i|threadseputs"EXCEPTION:#{e.inspect}"puts"MESSAGE:#{e.message}"end此代码在5秒后捕获异常。但是如果我将数组更改为[15,5,20,3],上面的代码会在15秒后捕获异常。简而言之,它总是捕获第一个线程中引发的异常。任何想法,为什么会这样。为什么每次3秒后不捕获异常?我如何捕获任何线程引发的第一个异常?
您可以创建异常的子类以使其更具描述性,但是您应该如何设置默认的“消息”?classMyErrorepe.messageendbeginraiseMyErrorraiseException=>epe.messageend第一个应该输出'Acustommessage'第二个应该输出'You'vetriggeredaMyError'关于最佳实践有什么建议吗? 最佳答案 定义一个初始化方法,它将消息作为具有默认值的参数。然后使用该消息调用StandardError的初始化方法(使用super)。classMyError
puts"hi"puts"bye"到目前为止,我想存储代码的STDOUT(在这种情况下,hi\nbye到变量say'result'中并打印它)putsresult我这样做的原因是我已经将一个R代码集成到我的Ruby代码中,当R代码运行时,它的输出被提供给STDOUT,但是无法在代码内部访问输出以进行一些评估。对不起,如果这令人困惑。所以“putsresult”行应该给我打个招呼。 最佳答案 一个方便的函数,用于将标准输出捕获到字符串中...以下方法是一个方便的通用工具,用于捕获标准输出并将其作为字符串返回。(我经常在单元测试中使用它
我正在从事rails项目,我正在尝试将异常记录到rails日志文件中。我知道我可以调用logger.error$!将异常的第一行记录到文件中。但是,我也想记录整个跟踪堆栈。如何使用默认的Rails记录器记录异常的整个回溯? 最佳答案 logger.error$!.backtrace还有,别忘了你可以rescueErrorType=>error_name为您的错误指定一个不同于默认$!的变量名。 关于ruby-on-rails-如何使用默认的Rails记录器记录Ruby异常的整个回溯?,我
我最近从Ruby的Net:HTTP类切换到rest-client1.6.7。我发现形成请求要容易得多,但与Net:HTTP请求不同,当rest-client收到200以外的任何内容时,请求就会终止。我已经尝试在RestClient.get之后直接放置一个断点,但它从未被击中-所以我做错了什么。defget_member_using_cardresource="#{@settings_app_uri}api/v1/card/#{self.member_card_num}?token=#{@settings.api_key}"response=RestClient.getresourcei
基本上只是检查以确保设置了url参数。我如何在PHP中做到这一点:if(isset($_POST['foo'])&&isset($_POST['bar'])){}这是RoR中isset()的粗略/最佳等价物吗?if(!params['foo'].nil?&&!params['bar'].nil?)end 最佳答案 更接近的匹配可能是#present?#returnstrueifnotnilandnotblankparams['foo'].present?还有一些其他的方法#returnstrueifnilparams['foo'].
我想命名从扫描中获取的字符串捕获。怎么做?"555-333-7777".scan(/(\d{3})-(\d{3})-(\d{4})/).flatten#=>["555","333","7777"]有没有可能变成这样{:area=>"555",:city=>"333",:local=>"7777"}或[["555","area"],[...]]我试过了"555-333-7777".scan(/((?)\d{3})-(\d{3})-(\d{4})/).flatten但它返回[] 最佳答案 您应该对命名捕获使用match,而不是scanm